For short-lived references rcu_lock_domain_by_id() is the better
(slightly cheaper) alternative.
Signed-off-by: Jan Beulich <jbeulich@suse.com>
Acked-by: Tamas K Lengyel <tamas@tklengyel.com>
Acked-by: Andrew Cooper <andrew.cooper3@citrix.com>
p2m_type_t t;
mfn_t o_mfn;
- d = get_domain_by_id(g->domain);
+ d = rcu_lock_domain_by_id(g->domain);
if ( d == NULL )
{
gdprintk(XENLOG_ERR,
d, g->gfn, mfn_x(mfn), p2m_ram_shared, t);
errors++;
}
- put_domain(d);
+ rcu_unlock_domain(d);
nr_gfns++;
}
/* The type count has an extra ref because we have locked the page */
rmap_del(gfn, cpage, 0);
rmap_add(gfn, spage);
put_count++;
- d = get_domain_by_id(gfn->domain);
+ d = rcu_lock_domain_by_id(gfn->domain);
BUG_ON(!d);
BUG_ON(set_shared_p2m_entry(d, gfn->gfn, smfn));
- put_domain(d);
+ rcu_unlock_domain(d);
}
ASSERT(list_empty(&cpage->sharing->gfns));
BUG_ON(!put_count);